sync point A 



sync point B 



sync point C 
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SPID 0000 



SPID 0001 



SPID 0002 




0000 ADD 'Cecile Licad 555-9876' 

0000 UPDATE 'Mitsuko Uchida, 555-1 11V 

0001 ADD 'Ceciie Licad 555-9876' 

0002 ADD 'Mitsuko Uchida, 555-1 11V 



SPID 0000 



SPID 0001 



SPID 0002 
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NRtsuko Uchida, S6S»1tt1 ' 5*38: fjwc:.:;; 




0001 


ADD 


'Cecile Licad 555-9876' 


0002 


ADD 


'Mitsuko Uchida, 555-1 111' 



t: 



Sync manager reads action table (if any) and 
truth database from previous 
synchronization from DSS in an atomic 
transaction 




Sync engine retrieves all contacts and their 
states from each sync point 
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Sync engine produces new truth database 
and action table 
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For each contact of each sync point, recovery 
module determines actual current state of 
the contact, based on action table and state 
of contact as retrieved from sync point 
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For any sync points that were offline during f)£ 
last synchronization, sync engine merges 
action table with new action table to 
produce effective action table 



Sync engine writes truth database and 
effective action table to DSS in an atomic 
transaction 
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I Sync engine updates each sync point * 



Sync engine deletes action table from DSS if 
update was successful for each sync point 
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Sync poir 
NO_CH 
(Take no 






Sync Engine records in 
the action table for all 
other sync points the 

intent to propagate that 
change 
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